package cn.edu.sgu.www.mhxysy.service.equipment;

import cn.edu.sgu.www.mhxysy.dto.equipment.EquipmentCategoryDTO;
import cn.edu.sgu.www.mhxysy.entity.equipment.EquipmentCategory;
import cn.edu.sgu.www.mhxysy.pager.equipment.EquipmentCategoryPager;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.springframework.web.multipart.MultipartFile;

import java.io.IOException;
import java.util.List;

/**
 * @author 沐雨橙风ιε
 * @version 1.0
 */
public interface EquipmentCategoryService {

	/**
	 * 上传图片
	 * @param file MultipartFile
	 * @return String
	 * @throws IOException uploadUtils.upload()方法抛出的异常
	 */
	String upload(MultipartFile file) throws IOException;

	/**
	 * 添加装备类型
	 * @param equipmentCategoryDTO 装备类型信息
	 */
	void insert(EquipmentCategoryDTO equipmentCategoryDTO);

	/**
	 * 通过id修改装备类型信息
	 * @param equipmentCategoryDTO 装备类型信息
	 */
	void updateById(EquipmentCategoryDTO equipmentCategoryDTO);

	/**
	 * 通过ID修改装备图片
	 * @param id 装备类型ID
	 * @param image 图片地址
	 */
	void updateImageById(Integer id, String image);

	/**
	 * 查询全部
	 * @return List<EquipmentCategory>
	 */
	List<EquipmentCategory> selectAll();

	/**
	 * 通过id查询装备类型
	 * @param id 装备类型id
	 * @return EquipmentCategory
	 */
	EquipmentCategory selectById(Integer id);

	/**
	 * 查询装备类型列表
	 * @param type 装备类型
	 * @return List<EquipmentCategory>
	 */
	List<EquipmentCategory> selectList(Integer type);

	/**
	 * 分页查询装备类型列表
	 * @param pager 查询条件
	 * @return Page<EquipmentCategory>
	 */
	Page<EquipmentCategory> selectByPage(EquipmentCategoryPager pager);
}